Evo C++ Library v0.5.1
Public Types | Public Member Functions | Public Attributes | Protected Member Functions | List of all members
SmartPtr< T[]> Class Template Reference

#include <evo/ptr.h>

Inheritance diagram for SmartPtr< T[]>:
Inheritance graph
[legend]

Detailed Description

template<class T>
class evo::SmartPtr< T[]>

Smart pointer to array.

See Managed Pointers

C++11:

Template Parameters
TType to use pointer to with array suffix, ex: int[]
Example
#include <evo/ptr.h>
using namespace evo;
int main() {
// Create array smart pointer, set a value (example only, better to use String)
SmartPtr<int[]> ptr(new int[3]);
*ptr = 1; // use dereference operator* like normal pointer
ptr[1] = 2; // use operator[] like normal array pointer
ptr[2] = 3;
// Copying array smart pointer not supported
//SmartPtr<int[]> ptr2(ptr); // Error
//ptr2 = ptr; // Error
} // ptr automatically freed

Public Types

typedef PtrBase< T, T * > Base
 This pointer base type. More...
 
typedef void EvoNullableType
 Identify as nullable type. More...
 
typedef T Item
 
typedef SmartPtr< T[]> This
 

Public Member Functions

 SmartPtr (T *ptr=NULL)
 Constructor. More...
 
 SmartPtr (This &&src)
 Move constructor (C++11). More...
 
 ~SmartPtr ()
 Destructor. More...
 
Thisclear ()
 Clear (free) pointer and set as null. More...
 
T * detach ()
 Detach and return pointer. More...
 
bool null () const
 Get whether pointer is null. More...
 
 operator SafeBoolType () const
 Safe (explicit) evaluation as bool type. More...
 
bool operator! () const
 Negation operator checks if NULL. More...
 
bool operator!= (const Base &ptr) const
 Inequality operator. More...
 
bool operator!= (void *ptr) const
 Inequality operator. More...
 
const T & operator* () const
 Dereference operator (const). More...
 
T & operator* ()
 Dereference operator (mutable). More...
 
const T * operator-> () const
 Member access operator (const). More...
 
T * operator-> ()
 Member access operator (mutable). More...
 
bool operator< (const Base &ptr) const
 Less-than operator. More...
 
bool operator< (void *ptr) const
 Less-than operator. More...
 
bool operator<= (const Base &ptr) const
 Less-than-or-equals operator. More...
 
bool operator<= (void *ptr) const
 Less-than-or-equals operator. More...
 
Thisoperator= (T *ptr)
 Assignment operator for new pointer. More...
 
Thisoperator= (This &&src)
 Move assignment operator (C++11). More...
 
bool operator== (const Base &ptr) const
 Equality operator. More...
 
bool operator== (void *ptr) const
 Equality operator. More...
 
bool operator> (const Base &ptr) const
 Greater-than operator. More...
 
bool operator> (void *ptr) const
 Greater-than operator. More...
 
bool operator>= (const Base &ptr) const
 Greater-than-or-equals operator. More...
 
bool operator>= (void *ptr) const
 Greater-than-or-equals operator. More...
 
const T & operator[] (ulong index) const
 Array access operator (const). More...
 
T & operator[] (ulong index)
 Array access operator (mutable). More...
 
const T * ptr () const
 Get current pointer (const). More...
 
T * ptr ()
 Get current pointer (mutable). More...
 
Thisset ()
 Set as null – same as clear(). More...
 
bool valid () const
 Get whether pointer is valid (not null). More...
 

Public Attributes

T * ptr_
 Pointer. More...
 

Protected Member Functions

void free ()
 

Member Typedef Documentation

◆ Base

typedef PtrBase<T,T* > Base
inherited

This pointer base type.

◆ EvoNullableType

typedef void EvoNullableType
inherited

Identify as nullable type.

◆ Item

typedef T Item

◆ This

typedef SmartPtr<T[]> This

Constructor & Destructor Documentation

◆ SmartPtr() [1/2]

SmartPtr ( T *  ptr = NULL)
inline

Constructor.

Parameters
ptrPointer to set, NULL for none

◆ ~SmartPtr()

~SmartPtr ( )
inline

Destructor.

◆ SmartPtr() [2/2]

SmartPtr ( This &&  src)
inline

Move constructor (C++11).

Parameters
srcSource to move

Member Function Documentation

◆ clear()

This& clear ( )
inline

Clear (free) pointer and set as null.

Returns
This

◆ detach()

T* detach ( )
inline

Detach and return pointer.

  • This returns current pointer and sets to null, releasing ownership
Returns
Pointer

◆ free()

void free ( )
inlineprotected

◆ null()

bool null ( ) const
inlineinherited

Get whether pointer is null.

Returns
Whether null

◆ operator SafeBoolType()

operator SafeBoolType ( ) const
inlineinherited

Safe (explicit) evaluation as bool type.

  • This is called when object is directly evaluated as a bool, and is equivalent to: !operator!()
  • See SafeBool

◆ operator!()

bool operator! ( ) const
inlineinherited

Negation operator checks if NULL.

Returns
Whether NULL

◆ operator!=() [1/2]

bool operator!= ( const Base ptr) const
inlineinherited

Inequality operator.

Parameters
ptrPointer to compare to
Returns
Whether not equal

◆ operator!=() [2/2]

bool operator!= ( void *  ptr) const
inlineinherited

Inequality operator.

Parameters
ptrPointer to compare to
Returns
Whether not equal

◆ operator*() [1/2]

const T& operator* ( ) const
inlineinherited

Dereference operator (const).

  • Results are undefined if pointer is NULL
Returns
Dereferenced pointer

◆ operator*() [2/2]

T& operator* ( )
inlineinherited

Dereference operator (mutable).

  • Results are undefined if pointer is NULL
Returns
Dereferenced pointer

◆ operator->() [1/2]

const T* operator-> ( ) const
inlineinherited

Member access operator (const).

  • Results are undefined if pointer is NULL
Returns
Pointer

◆ operator->() [2/2]

T* operator-> ( )
inlineinherited

Member access operator (mutable).

  • Results are undefined if pointer is NULL
Returns
Pointer

◆ operator<() [1/2]

bool operator< ( const Base ptr) const
inlineinherited

Less-than operator.

Parameters
ptrPointer to compare to
Returns
Whether less than ptr

◆ operator<() [2/2]

bool operator< ( void *  ptr) const
inlineinherited

Less-than operator.

Parameters
ptrPointer to compare to
Returns
Whether less than ptr

◆ operator<=() [1/2]

bool operator<= ( const Base ptr) const
inlineinherited

Less-than-or-equals operator.

Parameters
ptrPointer to compare to
Returns
Whether less than or equal to ptr

◆ operator<=() [2/2]

bool operator<= ( void *  ptr) const
inlineinherited

Less-than-or-equals operator.

Parameters
ptrPointer to compare to
Returns
Whether less than or equal to ptr

◆ operator=() [1/2]

This& operator= ( T *  ptr)
inline

Assignment operator for new pointer.

Parameters
ptrPointer to set
Returns
This

◆ operator=() [2/2]

This& operator= ( This &&  src)
inline

Move assignment operator (C++11).

Parameters
srcSource to move
Returns
This

◆ operator==() [1/2]

bool operator== ( const Base ptr) const
inlineinherited

Equality operator.

Parameters
ptrPointer to compare to
Returns
Whether equal

◆ operator==() [2/2]

bool operator== ( void *  ptr) const
inlineinherited

Equality operator.

Parameters
ptrPointer to compare to
Returns
Whether equal

◆ operator>() [1/2]

bool operator> ( const Base ptr) const
inlineinherited

Greater-than operator.

Parameters
ptrPointer to compare to
Returns
Whether greater than ptr

◆ operator>() [2/2]

bool operator> ( void *  ptr) const
inlineinherited

Greater-than operator.

Parameters
ptrPointer to compare to
Returns
Whether greater than ptr

◆ operator>=() [1/2]

bool operator>= ( const Base ptr) const
inlineinherited

Greater-than-or-equals operator.

Parameters
ptrPointer to compare to
Returns
Whether greater than or equal to ptr

◆ operator>=() [2/2]

bool operator>= ( void *  ptr) const
inlineinherited

Greater-than-or-equals operator.

Parameters
ptrPointer to compare to
Returns
Whether greater than or equal to ptr

◆ operator[]() [1/2]

const T& operator[] ( ulong  index) const
inlineinherited

Array access operator (const).

  • Results are undefined if pointer is NULL or index is out of bounds
Returns
Item reference

◆ operator[]() [2/2]

T& operator[] ( ulong  index)
inlineinherited

Array access operator (mutable).

  • Results are undefined if pointer is NULL or index is out of bounds
Returns
Item reference

◆ ptr() [1/2]

const T* ptr ( ) const
inlineinherited

Get current pointer (const).

  • Caution: This does not release ownership of the pointer
Returns
Current pointer, or NULL if none

◆ ptr() [2/2]

T* ptr ( )
inlineinherited

Get current pointer (mutable).

  • Caution: This does not release ownership of the pointer
Returns
Current pointer, or NULL if none

◆ set()

This& set ( )
inline

Set as null – same as clear().

Returns
This

◆ valid()

bool valid ( ) const
inlineinherited

Get whether pointer is valid (not null).

Returns
Whether valid

Member Data Documentation

◆ ptr_

T* ptr_
inherited

Pointer.


The documentation for this class was generated from the following file: